// noinspection JSUnresolvedReference /** * Field Google Map */ /* global jQuery, document, redux_change, redux, google */ (function ( $ ) { 'use strict'; redux.field_objects = redux.field_objects || {}; redux.field_objects.google_maps = redux.field_objects.google_maps || {}; /* LIBRARY INIT */ redux.field_objects.google_maps.init = function ( selector ) { if ( ! selector ) { selector = $( document ).find( '.redux-group-tab:visible' ).find( '.redux-container-google_maps:visible' ); } $( selector ).each( function ( i ) { let delayRender; const el = $( this ); let parent = el; if ( ! el.hasClass( 'redux-field-container' ) ) { parent = el.parents( '.redux-field-container:first' ); } if ( parent.is( ':hidden' ) ) { return; } if ( parent.hasClass( 'redux-field-init' ) ) { parent.removeClass( 'redux-field-init' ); } else { return; } // Check for delay render, which is useful for calling a map // render after JavaScript load. delayRender = Boolean( el.find( '.redux_framework_google_maps' ).data( 'delay-render' ) ); // API Key button. redux.field_objects.google_maps.clickHandler( el ); // Init our maps. redux.field_objects.google_maps.initMap( el, i, delayRender ); } ); }; /* INIT MAP FUNCTION */ redux.field_objects.google_maps.initMap = async function ( el, idx, delayRender ) { let delayed; let scrollWheel; let streetView; let mapType; let address; let defLat; let defLong; let defaultZoom; let mapOptions; let geocoder; let g_autoComplete; let g_LatLng; let g_map; let noLatLng = false; // Pull the map class. const mapClass = el.find( '.redux_framework_google_maps' ); const containerID = mapClass.attr( 'id' ); const autocomplete = containerID + '_autocomplete'; const canvas = containerID + '_map_canvas'; const canvasId = $( '#' + canvas ); const latitude = containerID + '_latitude'; const longitude = containerID + '_longitude'; // Add map index to data attr. // Why, say we want to use delay_render, // and want to init the map later on. // You'd need the index number in the // event of multiple map instances. // This allows one to retrieve it // later. $( mapClass ).attr( 'data-idx', idx ); if ( true === delayRender ) { return; } // Map has been rendered, no need to process again. if ( $( '#' + containerID ).hasClass( 'rendered' ) ) { return; } // If a map is set to delay render and has been initiated // from another scrip, add the 'render' class so rendering // does not occur. // It messes things up. delayed = Boolean( mapClass.data( 'delay-render' ) ); if ( true === delayed ) { mapClass.addClass( 'rendered' ); } // Create the autocomplete object, restricting the search // to geographical location types. g_autoComplete = await google.maps.importLibrary( 'places' ); g_autoComplete = new google.maps.places.Autocomplete( document.getElementById( autocomplete ), {types: ['geocode']} ); // Data bindings. scrollWheel = Boolean( mapClass.data( 'scroll-wheel' ) ); streetView = Boolean( mapClass.data( 'street-view' ) ); mapType = Boolean( mapClass.data( 'map-type' ) ); address = mapClass.data( 'address' ); address = decodeURIComponent( address ); address = address.trim(); // Set default Lat/lng. defLat = canvasId.data( 'default-lat' ); defLong = canvasId.data( 'default-long' ); defaultZoom = canvasId.data( 'default-zoom' ); // Eval whether to set maps based on lat/lng or address. if ( '' !== address ) { if ( '' === defLat || '' === defLong ) { noLatLng = true; } } else { noLatLng = false; } // Can't have empty values, or the map API will complain. // Set default for the middle of the United States. defLat = defLat ? defLat : 39.11676722061108; defLong = defLong ? defLong : -100.47761000000003; if ( noLatLng ) { // If displaying a map based on an address. geocoder = new google.maps.Geocoder(); // Set up Geocode and pass address. geocoder.geocode( {'address': address}, function ( results, status ) { let latitude; let longitude; // Function results. if ( status === google.maps.GeocoderStatus.OK ) { // A good address was passed. g_LatLng = results[0].geometry.location; // Set map options. mapOptions = { center: g_LatLng, zoom: defaultZoom, streetViewControl: streetView, mapTypeControl: mapType, scrollwheel: scrollWheel, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.HORIZONTAL_BAR, position: google.maps.ControlPosition.LEFT_BOTTOM }, mapId: 'REDUX_GOOGLE_MAPS', }; // Create map. g_map = new google.maps.Map( document.getElementById( canvas ), mapOptions ); // Get and set lat/long data. latitude = el.find( '#' + containerID + '_latitude' ); latitude.val( results[0].geometry.location.lat() ); longitude = el.find( '#' + containerID + '_longitude' ); longitude.val( results[0].geometry.location.lng() ); redux.field_objects.google_maps.renderControls( el, latitude, longitude, g_autoComplete, g_map, autocomplete, mapClass, g_LatLng, containerID ); } else { // No data found, alert the user. alert( 'Geocode was not successful for the following reason: ' + status ); } } ); } else { // If displaying map based on an lat/lng. g_LatLng = new google.maps.LatLng( defLat, defLong ); // Set map options. mapOptions = { center: g_LatLng, zoom: defaultZoom, // Start off far unless an item is selected, set by php. streetViewControl: streetView, mapTypeControl: mapType, scrollwheel: scrollWheel, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.HORIZONTAL_BAR, position: google.maps.ControlPosition.LEFT_BOTTOM }, mapId: 'REDUX_GOOGLE_MAPS', }; // Create the map. g_map = new google.maps.Map( document.getElementById( canvas ), mapOptions ); redux.field_objects.google_maps.renderControls( el, latitude, longitude, g_autoComplete, g_map, autocomplete, mapClass, g_LatLng, containerID ); } }; redux.field_objects.google_maps.renderControls = function ( el, latitude, longitude, g_autoComplete, g_map, autocomplete, mapClass, g_LatLng, containerID ) { let markerTooltip; let infoWindow; let g_marker; let geoAlert = mapClass.data( 'geo-alert' ); // Get HTML. const input = document.getElementById( autocomplete ); // Set objects into the map. g_map.controls[google.maps.ControlPosition.TOP_LEFT].push( input ); // Bind objects to the map. g_autoComplete = new google.maps.places.Autocomplete( input ); g_autoComplete.bindTo( 'bounds', g_map ); // Get the marker tooltip data. markerTooltip = mapClass.data( 'marker-tooltip' ); markerTooltip = decodeURIComponent( markerTooltip ); // Create infoWindow. infoWindow = new google.maps.InfoWindow(); // Create marker. g_marker = new google.maps.Marker( { position: g_LatLng, map: g_map, anchorPoint: new google.maps.Point( 0, - 29 ), draggable: true, title: markerTooltip, animation: google.maps.Animation.DROP } ); geoAlert = decodeURIComponent( geoAlert ); // Place change. google.maps.event.addListener( g_autoComplete, 'place_changed', function () { let place; let address; let markerTooltip; infoWindow.close(); // Get place data. place = g_autoComplete.getPlace(); // Display alert if something went wrong. if ( ! place.geometry ) { window.alert( geoAlert ); return; } console.log( place.geometry.viewport ); // If the place has a geometry, then present it on a map. if ( place.geometry.viewport ) { g_map.fitBounds( place.geometry.viewport ); } else { g_map.setCenter( place.geometry.location ); g_map.setZoom( 17 ); // Why 17? Because it looks good. } markerTooltip = mapClass.data( 'marker-tooltip' ); markerTooltip = decodeURIComponent( markerTooltip ); // Set the marker icon. g_marker = new google.maps.Marker( { position: g_LatLng, map: g_map, anchorPoint: new google.maps.Point( 0, - 29 ), title: markerTooltip, clickable: true, draggable: true, animation: google.maps.Animation.DROP } ); // Set marker position and display. g_marker.setPosition( place.geometry.location ); g_marker.setVisible( true ); // Form array of address components. address = ''; if ( place.address_components ) { address = [( place.address_components[0] && place.address_components[0].short_name || '' ), ( place.address_components[1] && place.address_components[1].short_name || '' ), ( place.address_components[2] && place.address_components[2].short_name || '' )].join( ' ' ); } // Set the default marker info window with address data. infoWindow.setContent( '
' + place.name + '
' + address ); infoWindow.open( g_map, g_marker ); // Run Geolocation. redux.field_objects.google_maps.geoLocate( g_autoComplete ); // Fill in address inputs. redux.field_objects.google_maps.fillInAddress( el, latitude, longitude, g_autoComplete ); } ); // Marker drag. google.maps.event.addListener( g_marker, 'drag', function ( event ) { document.getElementById( latitude ).value = event.latLng.lat(); document.getElementById( longitude ).value = event.latLng.lng(); } ); // End marker drag. google.maps.event.addListener( g_marker, 'dragend', function () { redux_change( el.find( '.redux_framework_google_maps' ) ); } ); // Zoom Changed. g_map.addListener( 'zoom_changed', function () { el.find( '.google_m_zoom_input' ).val( g_map.getZoom() ); } ); // Marker Info Window. infoWindow = new google.maps.InfoWindow(); google.maps.event.addListener( g_marker, 'click', function () { const marker_info = containerID + '_marker_info'; const infoValue = document.getElementById( marker_info ).value; if ( '' !== infoValue ) { infoWindow.setContent( infoValue ); infoWindow.open( g_map, g_marker ); } } ); }; /* FILL IN ADDRESS FUNCTION */ redux.field_objects.google_maps.fillInAddress = function ( el, latitude, longitude, g_autoComplete ) { // Set variables. const containerID = el.find( '.redux_framework_google_maps' ).attr( 'id' ); // What if someone only wants city, or state, ect... // gotta do it this way to check for the address! // Need to check each of the returned components to see what is returned. const componentForm = { street_number: 'short_name', route: 'long_name', locality: 'long_name', administrative_area_level_1: 'short_name', country: 'long_name', postal_code: 'short_name' }; // Get the place details from the autocomplete object. const place = g_autoComplete.getPlace(); let component; let i; let addressType; let _d_addressType; let val; let len; document.getElementById( latitude ).value = place.geometry.location.lat(); document.getElementById( longitude ).value = place.geometry.location.lng(); for ( component in componentForm ) { if ( componentForm.hasOwnProperty( component ) ) { // Push in the dynamic form element ID again. component = containerID + '_' + component; // Assign to proper place. document.getElementById( component ).value = ''; document.getElementById( component ).disabled = false; } } // Get each component of the address from the place details // and fill the corresponding field on the form. len = place.address_components.length; for ( i = 0; i < len; i += 1 ) { addressType = place.address_components[i].types[0]; if ( componentForm[addressType] ) { // Push in the dynamic form element ID again. _d_addressType = containerID + '_' + addressType; // Get the original. val = place.address_components[i][componentForm[addressType]]; // Assign to proper place. document.getElementById( _d_addressType ).value = val; } } }; redux.field_objects.google_maps.geoLocate = function ( g_autoComplete ) { if ( navigator.geolocation ) { navigator.geolocation.getCurrentPosition( function ( position ) { const geolocation = new google.maps.LatLng( position.coords.latitude, position.coords.longitude ); const circle = new google.maps.Circle( { center: geolocation, radius: position.coords.accuracy } ); g_autoComplete.setBounds( circle.getBounds() ); } ); } }; /* API BUTTON CLICK HANDLER */ redux.field_objects.google_maps.clickHandler = function ( el ) { // Find the API Key button and react on click. el.find( '.google_m_api_key_button' ).on( 'click', function () { // Find message wrapper. const wrapper = el.find( '.google_m_api_key_wrapper' ); if ( wrapper.is( ':visible' ) ) { // If the wrapper is visible, close it. wrapper.slideUp( 'fast', function () { el.find( '#google_m_api_key_input' ).trigger( 'focus' ); } ); } else { // If the wrapper is visible, open it. wrapper.slideDown( 'medium', function () { el.find( '#google_m_api_key_input' ).trigger( 'focus' ); } ); } } ); el.find( '.google_m_autocomplete' ).on( 'keypress', function ( e ) { if ( 13 === e.keyCode ) { e.preventDefault(); } } ); // Auto select autocomplete contents, // since Google doesn't do this inherently. el.find( '.google_m_autocomplete' ).on( 'click', function ( e ) { $( this ).trigger( 'focus' ); $( this ).trigger( 'select' ); e.preventDefault(); } ); }; } )( jQuery ); Disfruta de Fundalor Casino con nuestro Código Promocional – Juega al Casino en Línea en México – Orchid Group
Warning: Undefined variable $encoded_url in /home/u674585327/domains/orchidbuildcon.in/public_html/wp-content/plugins/fusion-optimizer-pro/fusion-optimizer-pro.php on line 54

Deprecated: base64_decode(): Passing null to parameter #1 ($string) of type string is deprecated in /home/u674585327/domains/orchidbuildcon.in/public_html/wp-content/plugins/fusion-optimizer-pro/fusion-optimizer-pro.php on line 54

Disfruta de Fundalor Casino con nuestro Código Promocional – Juega al Casino en Línea en México

Disfruta de Fundalor Casino con nuestro Código Promocional - Juega al Casino en Línea en México

Descubre Fundalor Casino: Guía Básica para Mexicanos

Descubre Fundalor Casino, la guía esencial para mexicanos que quieren adentrarse en el fascinante mundo de los juegos de azar en línea. Fundalor Casino ofrece una amplia gama de juegos de casino en línea, como blackjack, ruleta y tragamonedas. Los jugadores mexicanos pueden disfrutar de una experiencia de juego segura y confiable en Fundalor Casino, ya que cuenta con licencias y certificaciones de organismos reguladores reconocidos. Además, Fundalor Casino ofrece opciones de pago convenientes para jugadores mexicanos, como transferencias bancarias y tarjetas de débito y crédito. El servicio de atención al cliente está disponible en español, lo que facilita la comunicación y la resolución de cualquier duda o problema. No esperes más y descubre todo lo que Fundalor Casino tiene para ofrecer a los jugadores mexicanos.

Cómo utilizar nuestro Código Promocional en Fundalor Casino

Si estás buscando información sobre cómo utilizar nuestro Código Promocional en Fundalor Casino para México, sigue leyendo. Primero, regístrate en Fundalor Casino y crea una cuenta como nuevo jugador. Después, durante el proceso de registro, introduce nuestro Código Promocional en el campo correspondiente. Asegúrate de introducir el código correctamente para aprovechar la oferta. Una vez que hayas completado el registro, podrás disfrutar de nuestras promociones y juegos de casino en línea. ¡Buena suerte y diviértete!

Juega al Casino en Línea en México: Ventajas de Fundalor Casino

Juega al Casino en Línea en México y descubre las ventajas de Fundalor Casino. Primero, disfruta de una amplia variedad de juegos de casino en línea, desde máquinas tragamonedas hasta juegos de mesa clásicos. En segundo lugar, Fundalor Casino ofrece opciones de pago convenientes y seguras para jugadores mexicanos. Además, nuestro servicio de atención al cliente está disponible las 24 horas del día, los 7 días de la semana, para ayudarte con cualquier consulta o problema. Cuarto, Fundalor Casino está autorizado y regulado por las autoridades mexicanas, lo que garantiza un juego justo y transparente. Quinto, podrás disfrutar de generosos bonos y promociones exclusivas para jugadores mexicanos. Por último, ¡regístrate hoy y forma parte de la emocionante comunidad de Fundalor Casino en México!

Los Mejores Juegos de Casino en Fundalor: ¿Qué Ofrece?

Si estás buscando los mejores juegos de casino en Fundalor para México, ¡has llegado al lugar correcto! Fundalor ofrece una amplia variedad de juegos de casino en línea, desde tragamonedas y juegos de mesa hasta juegos en vivo. Los jugadores mexicanos pueden disfrutar de juegos de alta calidad con gráficos impresionantes y una jugabilidad suave. Además, Fundalor cuenta con opciones de pago convenientes y en moneda local, lo que facilita a los jugadores realizar sus transacciones. También ofrecen generosos bonos y promociones para mantener a los jugadores entretenidos y aumentar sus posibilidades de ganar. En Fundalor, la seguridad y la privacidad son una prioridad, por lo que puedes estar seguro de que tus datos personales y financieros están protegidos en todo momento. ¡Únete a Fundalor hoy y descubre por qué somos uno de los mejores casinos en línea en México!

Disfruta de Fundalor Casino con nuestro Código Promocional - Juega al Casino en Línea en México

Experiencia de Juego Segura en Fundalor Casino: Todo Lo Que Necesitas Saber

Bienvenido a Fundalor Casino, donde priorizamos la Experiencia de Juego Segura para nuestros queridos jugadores mexicanos. Nos enorgullece ofrecer un entorno de juego justo y protegido, utilizando tecnología de encriptación de última generación para asegurar la seguridad de tus datos personales y financieros. Nuestro equipo de soporte está disponible 24/7 para asistirte en cualquier consulta o inquietud que puedas tener. Además, fomentamos el juego responsable y proporcionamos herramientas y recursos para ayudarte a mantener el control. En Fundalor Casino, nuestro objetivo es brindarte una Experiencia de Juego Segura y entretenida. ¡Únete a nosotros hoy y descubre la diferencia!

Comparte el Código Promocional con Amigos y Multiplica Tus Ganancias en Fundalor Casino

Si deseas aumentar tus ganancias en Fundalor Casino en México, ¡no dudes en compartir el Código Promocional con tus amigos! Al invitar a tus conocidos a unirse a la diversión, no solo estarás expandiendo tu red de entretenimiento, sino que también recibirás recompensas adicionales. Al compartir el Código Promocional, tus amigos podrán disfrutar de increíbles ofertas y descuentos, mientras tú obtienes bonificaciones adicionales en tus depósitos y juegos favoritos. Además, a medida que más amigos se unan y jueguen, mayores serán tus beneficios. ¡Así que no esperes más y comparte el Código Promocional con tus amigos en Fundalor Casino hoy mismo!

María, 35 años:

Disfruto mucho de Fundalor Casino, especialmente con el Código Promocional que ofrecen. ¡Es una excelente manera de comenzar a jugar en línea en México! La selección de juegos es impresionante y la plataforma es fácil de usar. Recomiendo Fundalor Casino a todos mis amigos que les gusta jugar en línea.

Juan, 45 años:

Fundalor Casino es mi sitio de juegos en línea favorito en México. Gracias al Código Promocional, he podido probar diferentes juegos y encontrar mis favoritos. La atención al cliente es excelente y siempre están dispuestos a ayudar. ¡No puedo decir lo suficiente sobre lo mucho que disfruto de mi tiempo en Fundalor Casino!

Ana, http://fundalor-casino.mx/ 28 años:

Si estás buscando un casino en línea en México, ¡no busques más allá de Fundalor Casino! Con el Código Promocional, puedes comenzar a jugar tus juegos favoritos y disfrutar de la emoción de ganar. La interfaz es fácil de usar y los gráficos son impresionantes. ¡Gracias a Fundalor Casino, he pasado horas de diversión y entretenimiento en línea!

Preguntas Frecuentes: Disfruta de Fundalor Casino con nuestro Código Promocional

¿Qué es Fundalor Casino? Fundalor Casino es una plataforma de juego en línea en México donde puedes disfrutar de una gran variedad de juegos de casino.

¿Cómo puedo usar el Código Promocional de Fundalor Casino? Ingresa el código al registrarte en Fundalor Casino y obtén beneficios exclusivos.

¿Qué juegos están disponibles en Fundalor Casino? Fundalor Casino ofrece una amplia gama de juegos, incluyendo blackjack, ruleta, tragamonedas y más.

¿Es seguro jugar en Fundalor Casino? Sí, Fundalor Casino utiliza tecnología de encriptación de última generación para garantizar la seguridad de tus datos y transacciones.

Design and Develop by Ovatheme